Ancillary data (commonly abbreviated as ANC data), in the context of television systems, refers to a means which by non-video information (such as audio, other forms of essence, and metadata) may be embedded within the serial digital interface. Ancillary data is standardized by SMPTE as SMPTE 291M: Ancillary Data Packet and Space Formatting.
Contents |
Ancillary data packets may be located anywhere within a serial digital data stream, with the following exceptions:
Ancillary data packets are commonly divided into two types, depending on where they are located--specific packet types are often constrained to be in one location or another.
Note that ANC packets which lie in the dataspace which is in both the horizontal and vertical intervals, is considered to be HANC and not VANC.
VANC packets should be inserted in this manner:
All ANC packets must start with a start sequence; for component interfaces (the only kind of serial digital interface in widespread use today), the start sequence is 0 0x3FF 0x3FF. This sequence is otherwise illegal in the serial digital interface. (In the obsolete composite versions of SDI, the ANC start sequence is a single word, 0x3FC).
Three words immediately follow the start sequence in the header. The first word after the start sequence is the Data Identifier or DID, followed by either a 'Secondary Data Identifier (SDID) or a Data Block Number (DBN), followed by a Data Count (DC). After the Data Count word are 0 - 255 (inclusive) User Data Words (UDW), followed by a Checksum (CS) word.
The Data Identifier word (along with the SDID, if used), indicates the type of ancillary data that the packet corresponds to. Data identifiers range from 1 to 255 (FF hex), with 0 being reserved. As the serial digital interface is a 10-bit format, the DID word is encoded as follows:
Thus, a DID of 0x61 (01100001) would be encoded as 0x161 (0101100001), whereas a DID of 0x63 (01100011) would be encoded as 0x263 (1001100011). Note that this encoding scheme ensures that the reserved values in the serial digital interface (0-3 and 1020-1023) are never used.
If the DID is equal to 128 (0x80) or greater, then the packet is a Type 1 packet, and the DID is sufficient to identify the packet type, and the following word is a Data Block Number. If the DID is less than 128, it is a Type 2 packet, and the following words is the Secondary Data Identifier; the DID and SDID together identify the packet type.
The SDID is only valid if the DID is less than 0x80. The SDID is nominally an 8-bit value, ranging from 0 to 255. It is encoded in the same fashion as the DID.
DID/SDID words of 161 101 (hex) correspond to a DID of 61 hex, and a SDID of 1 (once the two high bits are removed); these values would indicate that the packet type is defined by SMPTE 334M, and contains DTV closed captions data.
The DBN is only valid if the DID is 80 hex or greater. It is (optionally) used to identify multiple packets of the same type within a field; each subsequent packet of the indicated type has a DBN which is one higher than the previous packet, wrapping around as necessary. The DBN is an 8-bit value, encoded in the same fashion as the SDID.
The Data Count word is an 8-bit value, encoded in the same fashion as the DID, which indicates how many user data words are to follow. It can range from 0 to 255.
User data words are the "payload" present in the ANC packet. They are defined according to the packet type, SMPTE 291M does not define their use or impose any restrictions on the values which may be present in the UDW space. The only restriction is that the reserved values in the serial digital interface (0-3 and 1020-1023) may not be included in the UDW. Many ANC formats, though not all, are essentially 8-bit formats, and encode data in the same manner that the header words are encoded.
Bits | Byte 1 | Byte 2 | Byte 3 | Byte 4 |
---|---|---|---|---|
Bit 7 | 1 | Interlaced (0) or Progressive (1) transport | Reserved | Reserved |
Bit 6 | 0 | Interlaced (0) or Progressive (1)picture | Horizontal Y´/Y sampling 1920 (0) or 2048 (1) | Reserved |
Bit 5 | 0 | Reserved | Reserved | Reserved |
Bit 4 | 0 | Reserved | Reserved | Dynamic range 100% (0h), 200% (1h), 400% (2h), Reserved (3h) |
Bit 3 | 1 | Picture Rate (see SMPTE 352M table 2) | Sampling structure (see SMPTE 352M table 3 and Note 1) | Dynamic range 100% (0h), 200% (1h), 400% (2h), Reserved (3h) |
Bit 2 | 0 | Picture Rate (see SMPTE 352M table 2) | Sampling structure (see SMPTE 352M table 3 and Note 1) | Reserved |
Bit 1 | 0 | Picture Rate (see SMPTE 352M table 2) | Sampling structure (see SMPTE 352M table 3 and Note 1) | Bit depth 8-bit (0h), 10-bit 81h), 12-bit (2h), Reserved (3h) |
Bit 0 | 1 | Picture Rate (see SMPTE 352M table 2) | Sampling structure (see SMPTE 352M table 3 and Note 1) | Bit depth 8-bit (0h), 10-bit 81h), 12-bit (2h), Reserved (3h) |
The last word in an ANC packet is the Checksum word. It is computed by computing the sum (modulo 512) of bits 0-8 (not bit 9), of all the other words in the ANC packet, excluding the packet start sequence. Bit 9 of the checksum word is then defined as the inverse of bit 8. Note that the checksum word does not contain a parity bit; instead, the parity bits of other words are included in the checksum calculations.
Ancillary data is used for several things:
Embedded audio is audio payload which is (typically) the soundtrack (music, dialogue, and sound effects) for the video program. Two standards, SMPTE 272M (for SD) and SMPTE 299M (for HD) define how audio is embedded into the ancillary space. Both standards provide for up to 16 channels of PCM audio, typically encoded in the AES3 format. In either case the embedded audio data packets are carried in the HANC space of Cb/Cr (chroma) parallel data stream.
In addition, both standards define audio control packets. The audio control packets are carried in the HANC space of the Y (luminance) parallel data steam and are inserted once per field at the second video line past the switching point (see SMPTE RP168 for switching points of various video standards). The audio control packet contains audio-related metadata, such as its timing relative to video, which channels are present, etc.
Embedded audio packets are Type 1 packets.
EDH packets are used for error detection in standard definition interfaces (they are not necessary in HD interfaces, as the HD-SDI interface includes CRC checkwords built in).